PHP 篇
GC
PHP 7
的内存回收原理?PHP 7
的垃圾回收和PHP 5
有什么区别?
结构
PHP 7
中对zVal
做了哪些修改?PHP 7
中哪些变量类型在栈,哪些变量类型在堆?变量在栈会有什么优势?
PHP 7
是如何让变量新建在栈的?- 详细描述
PHP
中HashMap
的结构是如何实现的? 下面代码中,在
PHP 7
下,$a
和$b
、$c
、$d
分别指向什么zVal
结构?$d
被修改的时候,PHP 7
/PHP 5
的内部分别会有哪些操作?$a = 'string'; $b = &$a; $c = &$b; $d = $b; $d = 'to';
JIT
是做了哪些优化,从而对PHP
的速度有不少提升?
字符串操作
strtr
和str_replace
有什么区别,两者分别用在什么场景下?strtr
的程序是如何实现的?- 字符串在手册中介绍,「PHP可安全用于二进制对象」,比如:
str_replace strpos str
等函数下都有这句话,这句话怎么理解,为什么是用于二进制是安全的? 字符串连接符
.
,在PHP内核中有哪些操作?多次
.
连接,是否会造成内存碎片过多?
性能分析
- 线上环境中,
PHP进程
偶尔会卡死(或者运行卡顿),请问如何检测本质问题?
中间件
Laravel
的中间件的顺序执行,类似于下面的管道的实现,请实现管道的makeFn
函数function pipe($input, $list) { $fn = makeFn($list); return $fn($input); } $r = pipe(0, [$a, $b, $c]); echo $r; //$a, $b, $c 类似于 $a = function($input, $next) { $input++; $output = $next($input); return $output; }; function makeFn($list){ //请实现 }
实现
- 用
PHP
实现一个定时任务器,类似crontab
,需要做到前一个任务不论运行时长、运行失败,都不能影响下一个任务的准点执行?
安全
RSA
AES
加密的区别,分别用于什么场景下?
反射
实现如下curry函数(PHP 7)
echo a(1, 3); //4 echo a(3)(5); //8 echo a(1, 2)(3, 4, 5)(6); //21
- 如何读取某函数的参数列表,以及参数的默认值。
- 如何模拟Java的注解方法,比如识别如下代码中的路由
- PHP 8中的注解
#Function(xxx)
需要如何实现
class Controller {
/**
* @Route("/", name="index")
* @CheckRequest
*/
public function index(Request $request){
return 'result';
}
}
- 描述下
IoC
(DI
)的实现原理?
算法
目前有
{} () [] <>
四种配对符号,要求写一个算法检查类似{([()()]<()>)}
是否配对(此字符串是正确的配对),比如
{([() --- (]) --- <()>)}
即是不合规,因为---
标记的部分(])
让]
被隔断这种符号配对算法常用于语法判断,比如IDE。(下面是配对示例),比如以下PHP代码中的括号不论如何嵌套,都必须保持配对的原则才能通过编译:
if ($a) { $user['posts'][ $user['id_list'][ User::get($request['token'])['id'] ] ] = null; }
- 生成2亿个优惠券码,长度在14位,有效字符是
3456789ABCDEFGHJKMNPQRSTUVWXY
,其中不含有印刷歧义的0 O 1 I L 2 Z
。需要快速生成并设计一个结构,能快速发放,并且快速验证是否已经被使用 写一个最长匹配的替换算法,比如字符串
aabcabcabaa
根据下面替换关系,得到的结果是1345
,最长匹配会这样分割:aabc abc ab aa
替换对应关系如下
ab => 4 aa => 5 aabc => 1 abc => 3
- 有一个文件,保存了20亿行的数字,每个数字长度在5-10之间,这些数字中有很多重复,设计一个算法在只有2核1G内存的电脑上对这些数字快速去重并保存?
数据库篇
- 搭建
MySQL
分布式,有哪些方式? MySQL
主从同步,和主主同步有哪些区别,以及优劣势?Laravel
中,多态一对多,多态多对多,数据库要怎么设计?比如一个关键词表
tags
,需要关联用户、帖子、评论、视频等表。- 描述
MySQL
的注入原理,以及防止注入有哪些方式? 怎么解决数据库中常见的 N+1 效率问题
比如:
$users = SELECT * FROM `users` WHERE `gender` = 'male'; foreach ($users as &$user) $user['posts'] = SELECT * FROM `posts` WHERE `user_id` = $user['id'];
MySQL
中脏读应该怎么处理?引申:比如京东的库存,0点多人抢购的时候库存问题?
如下数据库中会有哪些值
//请注意是多重嵌套事务 START TRANSACTION; INSERT INTO `users` (`name`) VALUES('a'); START TRANSACTION; INSERT INTO `users` (`name`) VALUES('b'); START TRANSACTION; INSERT INTO `users` (`name`) VALUES('c'); ROLLBACK; COMMIT; ROLLBACK;
MySQL
默认隔离RR下,行锁在什么情况下会退化为表锁?- 为什么
MySQL
使用B+
树,而不是其它树,比如红黑树
? MySQL
在什么时候会不使用索引?Elasticsearch
如何实现类似SQL
的WHERE id = 12 AND gender IN ('male', 'unknow');
Elasticsearch
如何实现类似SQL
的GROUP BY nickname, gender
Redis
是如何保证执行的原子性的?Redis
有哪些数据结构,其中的set
、sorted set
、bitmap
,bloom filter
用于什么场景?Redis
在事务中如何做到:发现事务执行过程中数据被污染就回滚执行?
前端篇
- 描述
XSS
注入原理,以及如何防止? - 描述
Csrf
注入原理,以及如何防止?
通讯协议篇
- 详细描述
HTTPS
(SSL
)工作原理? - Web服务器,客户端的
IP
能伪造吗?如果能,列出伪造方法;如果不能,说明原因? - 描述域名劫持的各种方法,为什么
HTTPS
不能被劫持? - 描述
HTTP协议
是什么,以及HTTP 2
和HTTP 1.1
有什么区别? - 详细描述
IP协议
、TCP协议
,以及UDP协议
与它们的区别。 TCP协议
中,最大传输单元MTU
一般最大是多少,在TCP协议
中,如果一个数据被分割成多个包,这些包结构中什么字段会被标记相同。
UDP
分包和TCP
分包会有哪些区别?HTTP协议
中Transfer-Encoding: Chunked
适用于哪些应用场景,这个与使用Content-Length: xxx
在收到的报文包上有哪些区别?
分布式篇
- 描述
epoll
和poll、select
的区别,为什么epoll
会具备性能优势? - 描述下
惊群
的原因?有什么有效的方法可以避免惊群? - 什么是
Hash一致性
,这个方法主要运用在什么场景?
如何实现增加新节点之后,整体做最小的数据移动 - 有哪些常见分布式锁的解决方案,
Redis
如何完成一个分布式锁? ZooKeeper
、Etcd
能解决哪些问题?具体说明。
综合篇
- 比如: 我国在
2020年1月1日08:00:00
时, 东京是2020年1月1日09:00:00
, 请问他们此时的时间戳差异多少? - 描述
OAuth2
的工作原理,绘制出其工作的时序图? Swoole 或 Go
中协程实现原理,以及为什么会提升效率?Swoole
服务端启动后有哪些进程,这些进程分别是完成什么工作?- 列出几个中文分词工具?
git
放弃未提交的文件有哪些方法?
git
删除远程分支、Tag
有什么方法?
git
覆盖远程仓库有什么办法?
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。